<template lang="pug">
el-table(:data='list' border='' fit='' highlight-current-row='' style='width: 100%')
  el-table-column(v-loading='loading' align='center' label='ID' width='65' element-loading-text='请给我点时间！')
    template(slot-scope='scope')
      span {{ scope.row.id }}
  el-table-column(width='180px' align='center' label='Date')
    template(slot-scope='scope')
      span {{ scope.row.timestamp | parseTime('{y}-{m}-{d} {h}:{i}') }}
  el-table-column(min-width='300px' label='Title')
    template(slot-scope='{row}')
      span {{ row.title }}
      el-tag {{ row.type }}
  el-table-column(width='110px' align='center' label='Author')
    template(slot-scope='scope')
      span {{ scope.row.author }}
  el-table-column(width='120px' label='Importance')
    template(slot-scope='scope')
      svg-icon(v-for='n in +scope.row.importance' :key='n' icon-class='star')
  el-table-column(align='center' label='Readings' width='95')
    template(slot-scope='scope')
      span {{ scope.row.pageviews }}
  el-table-column(class-name='status-col' label='Status' width='110')
    template(slot-scope='{row}')
      el-tag(:type='row.status | statusFilter')
        | {{ row.status }}
</template>

<script>
import { fetchList } from '@/api/article'

export default {
  filters: {
    statusFilter(status) {
      const statusMap = {
        published: 'success',
        draft: 'info',
        deleted: 'danger'
      }
      return statusMap[status]
    }
  },
  props: {
    type: {
      type: String,
      default: 'DETAIL'
    }
  },
  data() {
    return {
      list: null,
      listQuery: {
        page: 1,
        limit: 5,
        type: this.type,
        sort: '+id'
      },
      loading: false
    }
  },
  created() {
    this.getList()
  },
  methods: {
    getList() {
      this.loading = true
      this.$emit('create') // for test
      fetchList(this.listQuery).then(response => {
        this.list = response.data.items
        this.loading = false
      })
    }
  }
}
</script>
